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WHAT IS CLAIMED IS: 

1 . A method comprising: 
receiving configuration data that indicates which one of a plurality of memory 

controllers will support each of a plurality of clients, 
receiving data access requests from each of the plurality of clients; and 
^routing each of the data access requests to one of the plurality of memory controllers 
based on the configuration data. 

2. The method as in Claim 1, wherein the plurality of clients and the plurality of 
memory controllers are integrated on a single device. 

3. The method asm Claim 2, wherein the single device is a semiconductor device. 



4. The method as in Claipi 3, wherein the semiconductor device includes a graphics 
controller. 



The method as in Claim 1 , wfterein data access requests routed to the plurality of 
memory controllers are executeckby the plurality of memory controllers in the order 
in which the data access requests ate received. 

The method as in Claim 1, wherein the plurality of clients include at least two clients 
having a common client type. 



The method as in Claim 6, wherein the common cH^nt type includes one of the group 
of a two-dimensional graphics driver, a three dimensional graphics driver, and an 
audio driver. 
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il 8. The method as in Claim 6, wherein the step of routing includes routing access 

requests from a first client having the common client type to a first memory controller 
and routing access requests from a second client having the common client type to a 
second memory controller. 

sThe method as in Claim 8, wherein the first memory controller executes a first portion 
oiSan access request and the second memory controller executes a second portion of 
the ais^ess request. 

The methoosas in Claim 6, wherein the step of routing includes routing access 
requests from V first client having the common client type to a first memory controller 
and routing access requests from a second client having the common client type to the 
first memory controller. 

The method as in Claim 6)^vherein the step of routing includes routing a first access 
request from a first client having the common client type to a first memory controller 
and routing a second access request from a second client having the common client 
type to the first memory controller^ wherein the first and second access requests are 
simultaneously pending at the first memory controller. 

The method as in Claim 1 1 further comprising a step of prioritizing one of the first 
access request and the second access request oased upon a predefined arbitration 
scheme. \ 

The method as in Claim 12, wherein the predefined arbitration scheme is a round 
robin arbitration scheme. \ 
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14. The method as in Claim 12, wherein the predefined arbitration scheme prioritizes 
access requests from the first client over access requests from the second client. 

"The method as in Claim 1 1 further comprising a step of prioritizing one of the first 
access request and the second access request based upon a first predefined arbitration 
schema when the first and the second access requests are from clients having a first 
commondient type, and prioritizing one of the first access request and the second 
access request based upon a second predefined arbitration scheme when the first and 
the second access requests are from clients having a first common client type. 

The method as in Clann 15, wherein a priority assigned to the access requests is 
dynamic. \ 

The method as in Claim 16, whetein the priority assigned depends on an identifier 
within the access request. \ 

The method as in Claim 16, wherein the priority assigned depends on an internal 
timer. \ 

The method as in Claim 1, wherein client requests aresrouted based on one or more 
of: an address, a client identifier, client tag information, and data size. 

The method as in Claim 1, wherein the number of requests routefcL to a memory 
controller, from a particular client, is dependent on the data rate of nae particular 
client. \ 

The method as in Claim 1, wherein the plurality of memory controllers are scalable. 
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1 ^2. The method as in Claim 1 $ wherein: 

2 \the step of receiving data access requests includes receiving a first HDTV stream and 

3 a second HDTV stream; and 

4 the stejrstf routing includes: 

5 routmg the first HDTV stream to the first memory controller; and 

6 routing tnbssecond HDTV stream to the second memory controller. 



1 23. The method as in Claim 1 , wfibrein one of the plurality of memory controllers is 

2 dedicated for use in handling requests received from a high-data rate client, where the 

3 high-data rate client requests a greater amount of data than other clients. 
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1 ^4. An apparatus comprising: 

2 \ a storage module having a memory location and an output port, the memory location 

3 \ to store data; 

4 aSplurality of clients, each of the plurality of clients having a data access port; 

5 a roUter having a plurality of first-input ports coupled to the data access port of each 

6 \nf the plurality of clients, a second input port coupled to the output port of the 

7 storage module, a first plurality of output ports, and a second plurality of 

8 output ports, wherein the router is to route data at one each one of its plurality 

9 of first- input ports to its respective output port of the first or second output 

10 port based troon the data stored in the storage module; 

1 1 a first memory controller having a plurality of input ports coupled to the first plurality 

12 of output ports orsthe router; 

13 a second memory controllervhaving a plurality of input ports coupled to the second 

14 plurality of output porw>f the router; and 

15 a first arbiter having a plurality olSmput ports coupled to the first plurality of output 

16 ports of the router, and an outout port, wherein the first arbiter selects one a 

17 data access request on one of thMirst plurality of input ports to be provide to 

18 the output port. \ 

1 25. The apparatus of claim 24, further including: \ 

2 a second arbiter to receive a plurality of client requests from a plurality of clients, to 

3 route each of said requests to one of a plurality\f memory controllers based 

4 on a programmable value; and \ 

5 a plurality of memory controllers to order client requests, anOyto deliver said ordered 

6 client requests to memory, at least two of the plurality o^clients having a 

7 common type. \ 

1 26. The apparatus as in Claim 24, wherein said first memory controller and sW second 

2 memory controller include arbiters, said arbiters to order client requests. \ 
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1 \27. The apparatus as in Claim 26, wherein said arbiters perform round robin arbitration 

2 \ between clients having a common type. 

1 28. The apparatus as in Claim 26, wherein said arbiters performing a first arbitration 

2 between clients having a common type, and a second arbitration between clients 

3 having^different types. 

1 29. The apparatuses in Claim 24, wherein said router routes a first client request from a 

2 first client to a first memory controller, and routes a second client request from a 

3 second client, the second client being the same client type as the first client, to a 

4 second memory controller. 

)\{ l 30. The apparatus as in Claim 24, wherein said router routes the client requests based on 

fll \ 

hi 2 one or more of: an address, a\lient identifier, client tag information, and data size. 

Ill \ 

lis \ 

3 1 31. The apparatus as in Claim 24, wherein the number of requests routed to a memory 

J ;( 2 controller, from a particular client, is oependent on the data rate of the particular 

ill \ 

£3 3 client. \ 

1 32. The apparatus as in Claim 24, wherein said plurality of memory controllers are 

2 scalable. \ 

1 33. The apparatus as in Claim 24, wherein: \ 

2 said router receives a first HDTV stream from a first client and a second HDTV 

3 stream from a second client; and wherein \ 

4 said router routes the first HDTV stream to a first memory controller and routes the 

5 second HDTV stream to a second memory controller. \ 
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1 34. • The appSa!nr^s-«i-CJai£n_24 L wherein one of said plurality of memory controllers is 

2 dedicated for use in handling requests received from a high-data rate client. 
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35. A method comprising: 

receiving a first client request from a first video decoder; 
routing the first client request to a first memory controller; 
iseceiving a second client request from a second video decoder; and 
routing the second client request to a second memory controller. 

The method as in Claim 35, further including providing the first client request to a 
first membry and the second client request to a second memory. 

The method as\n Claim 35, wherein routing is based on one or more of: an address, a 
client identifier, client tag information, and data size. 

The method as in Claim 35, wherein the number of requests routed to a memory 
controller, from a particular client, is dependent on the data rate of the particular 
client. \ 

The method as in Claim 5, wherein the memory controllers are scalable. 

The method as in Claim 35, wherein: \ 

the first video decoder is an MPEG decoder; 
the first client request is a first HDTV stream\ 
the second video decoder is. an MPEG decoder; Mid 
the second client request is a second HDTV stream. \ 
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1 41 . The methocTaST ii Claim 35, wherei n o n e o Xjh^memory controllers is dedicated for 

2 use in handling requests received from a high-data rate client. 
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